//给定一个经过编码的字符串，返回它解码后的字符串。 
//
// 编码规则为: k[encoded_string]，表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。 
//
// 你可以认为输入字符串总是有效的；输入字符串中没有额外的空格，且输入的方括号总是符合格式要求的。 
//
// 此外，你可以认为原始数据不包含数字，所有的数字只表示重复的次数 k ，例如不会出现像 3a 或 2[4] 的输入。 
//
// 
//
// 示例 1： 
//
// 
//输入：s = "3[a]2[bc]"
//输出："aaabcbc"
// 
//
// 示例 2： 
//
// 
//输入：s = "3[a2[c]]"
//输出："accaccacc"
// 
//
// 示例 3： 
//
// 
//输入：s = "2[abc]3[cd]ef"
//输出："abcabccdcdcdef"
// 
//
// 示例 4： 
//
// 
//输入：s = "abc3[cd]xyz"
//输出："abccdcdcdxyz"
// 
//
// 
//
// 提示： 
//
// 
// 1 <= s.length <= 30 
// 
// s 由小写英文字母、数字和方括号
// '[]' 组成 
// s 保证是一个 有效 的输入。 
// s 中所有整数的取值范围为
// [1, 300] 
// 
//
// Related Topics 栈 递归 字符串 👍 1236 👎 0

package leetcode.editor.cn;

import java.util.ArrayDeque;
import java.util.Deque;
import java.util.LinkedList;

public class _394_DecodeString {
    public static void main(String[] args) {
        String s = "3[a2[c]]";      // accaccacc
        Solution solution = new _394_DecodeString().new Solution();
        System.out.println(solution.decodeString(s));
    }

    class Solution {
        public String decodeString(String s) {
            StringBuilder res = new StringBuilder();
            int multi = 0;
            LinkedList<Integer> stack_multi = new LinkedList<>();
            LinkedList<String> stack_res = new LinkedList<>();
            for (Character c : s.toCharArray()) {
                if (c == '[') {
                    stack_multi.addLast(multi);
                    stack_res.addLast(res.toString());
                    multi = 0;
                    res = new StringBuilder();
                } else if (c == ']') {
                    StringBuilder tmp = new StringBuilder();
                    int cur_multi = stack_multi.removeLast();
                    for (int i = 0; i < cur_multi; i++) {
                        tmp.append(res);
                    }
                    res = new StringBuilder(stack_res.removeLast() + tmp);
                } else if (c >= '0' && c <= '9') {
                    multi = multi * 10 + Integer.parseInt(c+ "");// Integer.parseInt(String.valueOf(s.charAt(i)));
                } else {
                    res.append(c);
                }
            }
            return res.toString();
        }
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution1 {
        public String decodeString(String s) {
            Deque<Character> stack = new ArrayDeque<>();
            StringBuilder res = new StringBuilder();
            for (char c : s.toCharArray()) {
                if (c == ']') {
                    StringBuilder tmp = new StringBuilder();
                    char temp;
                    while ((temp = stack.removeLast()) != '[') {
                        tmp.append(temp);
                    }
                    String ziMu = tmp.reverse().toString();
                    tmp.delete(0, tmp.length());
                    while (Character.isDigit(temp = stack.removeLast())) {
                        tmp.append(temp);
                    }
                    int count = Integer.parseInt(tmp.reverse().toString());
                    while (count > 0) {
                        res.append(ziMu);
                        count--;
                    }
                } else {
                    stack.addLast(c);
                }
            }
            return res.toString();
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}